package leetcode.editor.cn;
//有效 IP 地址 正好由四个整数（每个整数位于 0 到 255 之间组成，且不能含有前导 0），整数之间用 '.' 分隔。 
//
// 
// 例如："0.1.2.201" 和 "192.168.1.1" 是 有效 IP 地址，但是 "0.011.255.245"、"192.168.1.312" 
//和 "192.168@1.1" 是 无效 IP 地址。 
// 
//
// 给定一个只包含数字的字符串 s ，用以表示一个 IP 地址，返回所有可能的有效 IP 地址，这些地址可以通过在 s 中插入 '.' 来形成。你 不能 重新
//排序或删除 s 中的任何数字。你可以按 任何 顺序返回答案。 
//
// 
//
// 示例 1： 
//
// 
//输入：s = "25525511135"
//输出：["255.255.11.135","255.255.111.35"]
// 
//
// 示例 2： 
//
// 
//输入：s = "0000"
//输出：["0.0.0.0"]
// 
//
// 示例 3： 
//
// 
//输入：s = "101023"
//输出：["1.0.10.23","1.0.102.3","10.1.0.23","10.10.2.3","101.0.2.3"]
// 
//
// 
//
// 提示： 
//
// 
// 1 <= s.length <= 20 
// s 仅由数字组成 
// 
//
// Related Topics 字符串 回溯 👍 1371 👎 0


import java.util.LinkedList;
import java.util.List;
import java.util.stream.Collectors;

//leetcode submit region begin(Prohibit modification and deletion)
class Solution261 {

    LinkedList<String> res = new LinkedList<>();
    LinkedList<String> trace = new LinkedList<>();

    public List<String> restoreIpAddresses(String s) {
        // 如果长度不够，不搜索
        if (s.length() < 4 || s.length() > 12) {
            return res;
        }
        dfs(s, 0);
        return res;
    }

    private void dfs(String s, int start) {
        if (trace.size() == 4 && start == s.length()) {
            res.add(String.join(".", trace));
            return;
        }
        // 下标超界就拜拜
        if (start >= s.length()) return;
        // 第一次字母为0，考虑把第一个字母尝试加进去
        if (s.charAt(start) == '0') {
            trace.add("0");
            dfs(s, start + 1);
            trace.removeLast();
            return;
        }
        // 第一个字母不为0
        for (int i = start; i - start <= 3 && i < s.length(); i++) {
            String cur = s.substring(start, i + 1);
            // 当前大于255，后续只会更大
            if (Integer.parseInt(cur) > 255) break;
            trace.add(cur);
            dfs(s, i + 1);
            trace.removeLast();
        }
    }
}
//leetcode submit region end(Prohibit modification and deletion)
